home *** CD-ROM | disk | FTP | other *** search
/ SGI Freeware 1999 August / SGI Freeware 1999 August.iso / dist / fw_gimp.idb / usr / freeware / share / gimp / scripts / ripply-anim.scm.z / ripply-anim.scm
Encoding:
GIMP Script-Fu Script  |  1999-07-21  |  3.9 KB  |  103 lines

  1. ; "Rippling Image" animation generator (ripply-anim.scm)
  2. ; Adam D. Moss (adam@foxbox.org)
  3. ; 97/05/18
  4. ;
  5. ; Designed to be used in conjunction with a plugin capable
  6. ; of saving animations (i.e. the GIF plugin).
  7. ;
  8.  
  9. (define (copy-layer-ripple dest-image dest-drawable source-image source-drawable)
  10.   (gimp-selection-all dest-image)
  11.   (gimp-edit-clear dest-image dest-drawable)
  12.   (gimp-selection-none dest-image)
  13.   (gimp-selection-all source-image)
  14.   (gimp-edit-copy source-image source-drawable)
  15.   (gimp-selection-none source-image)
  16.       (let ((floating-sel (car (gimp-edit-paste dest-image dest-drawable FALSE))))
  17.     (gimp-floating-sel-anchor floating-sel)))
  18.  
  19. (define (script-fu-ripply-anim img drawable displacement num-frames)
  20.   (let* ((width (car (gimp-drawable-width drawable)))
  21.      (height (car (gimp-drawable-height drawable)))
  22.      (ripple-image (car (gimp-image-new width height GRAY)))
  23.      (ripple-layer (car (gimp-layer-new ripple-image width height GRAY_IMAGE "Ripple Texture" 100 NORMAL))))
  24.  
  25.  ; this script generates its own displacement map
  26.  
  27.     (gimp-image-disable-undo ripple-image)
  28.     (gimp-palette-set-background '(127 127 127) )
  29.     (gimp-image-add-layer ripple-image ripple-layer 0)
  30.     (gimp-edit-fill ripple-image ripple-layer)
  31.     (plug-in-noisify 1 ripple-image ripple-layer FALSE 1.0 1.0 1.0 0.0)
  32.     ; tile noise
  33.     (set! rippletiled-ret (plug-in-tile 1 ripple-image ripple-layer (* width 3) (* height 3) TRUE))
  34.     (gimp-image-enable-undo ripple-image)
  35.     (gimp-image-delete ripple-image)
  36.  
  37.     (set! rippletiled-image (car rippletiled-ret))
  38.     (set! rippletiled-layer (cadr rippletiled-ret))
  39.     (gimp-image-disable-undo rippletiled-image)
  40.  
  41.     ; process tiled noise into usable displacement map
  42.     (plug-in-gauss-iir 1 rippletiled-image rippletiled-layer 35 TRUE TRUE)
  43.     (gimp-equalize rippletiled-image rippletiled-layer TRUE)
  44.     (plug-in-gauss-rle 1 rippletiled-image rippletiled-layer 5 TRUE TRUE)
  45.     (gimp-equalize rippletiled-image rippletiled-layer TRUE)
  46.  
  47.     ; displacement map is now in rippletiled-layer of rippletiled-image
  48.  
  49.     ; loop through the desired frames
  50.  
  51.     (set! remaining-frames num-frames)
  52.     (set! xpos (/ width 2))
  53.     (set! ypos (/ height 2))
  54.     (set! xoffset (/ width num-frames))
  55.     (set! yoffset (/ height num-frames))
  56.  
  57.     (let* ((out-imagestack (car (gimp-image-new width height RGB))))
  58.  
  59.       (gimp-image-disable-undo out-imagestack)
  60.       
  61.       (while (> remaining-frames 0)
  62.          (set! dup-image (car (gimp-channel-ops-duplicate rippletiled-image)))
  63.          (gimp-image-disable-undo dup-image)
  64.          (gimp-crop dup-image width height xpos ypos)
  65.          
  66.          (set! layer-name (string-append "Frame " 
  67.             (number->string (- num-frames remaining-frames) 10)))     
  68.          (set! this-layer (car (gimp-layer-new out-imagestack 
  69.                            width height RGB 
  70.                            layer-name 100 NORMAL)))
  71.          (gimp-image-add-layer out-imagestack this-layer 0)
  72.          
  73.          (copy-layer-ripple out-imagestack this-layer img drawable)
  74.          
  75.          (set! dup-layer (car (gimp-image-get-active-layer dup-image)))
  76.          (plug-in-displace 1 out-imagestack this-layer 
  77.                    displacement displacement 
  78.                    TRUE TRUE dup-layer dup-layer 2)
  79.          
  80.          (gimp-image-enable-undo dup-image)
  81.          (gimp-image-delete dup-image)
  82.          
  83.          (set! remaining-frames (- remaining-frames 1))
  84.          (set! xpos (+ xoffset xpos))
  85.          (set! ypos (+ yoffset ypos)))
  86.       
  87.       (gimp-image-enable-undo rippletiled-image)
  88.       (gimp-image-delete rippletiled-image)
  89.       (gimp-image-enable-undo out-imagestack)
  90.       (gimp-display-new out-imagestack))))
  91.  
  92. (script-fu-register "script-fu-ripply-anim"
  93.             "<Image>/Script-Fu/Animators/Rippling"
  94.             "Ripple any image by creating animation frames as layers"
  95.             "Adam D. Moss (adam@foxbox.org)"
  96.             "Adam D. Moss"
  97.             "1997"
  98.             "RGB*, GRAY*"
  99.             SF-IMAGE "Image to Animage" 0
  100.             SF-DRAWABLE "Drawable to Animate" 0
  101.             SF-VALUE "Rippling Strength" "3"
  102.             SF-VALUE "Number of Frames" "15")
  103.